草庐IT

JavaScript 正则表达式空白字符

全部标签

ruby - 正则表达式蛋白质消化

所以,我正在用一种enzyme(出于好奇,Asp-N)消化蛋白质序列,这种enzyme在单字母编码序列中由B或D编码的蛋白质之前切割。我的实际分析使用String#scan进行捕获。我试图弄清楚为什么以下正则表达式不能正确消化它...(\w*?)(?=[BD])|(.*\b)前提(.*\b)存在以捕获序列的末尾。对于:MTMDKPSQYDKIEAELQDICNDVLELLDSKGDYFRYLSEVASGDN这应该给出如下内容:[MTM,DKPSQY,DKIEAELQ,DICN,DVLELL,DSKG,...]但会遗漏序列中的每个D。我一直在使用http://www.rubular.co

ruby - 如何在正则表达式中使用双括号?

正则表达式中的双方括号是什么意思?我对以下示例感到困惑:/[[^abc]]//[^abc]/我正在使用Rubular进行测试,但我没有看到双括号和单括号之间的任何区别。 最佳答案 Posixcharacterclasses使用[:alpha:]符号,它在正则表达式中使用,例如:/[[:alpha:][:digit:]]/您需要向下滚动以获取上面链接中的Posix信息。来自文档:POSIXbracketexpressionsarealsosimilartocharacterclasses.Theyprovideaportablealt

ruby-on-rails - 如何使用字符串调用名为范围的事件记录

我确定我没有理解call的用法,但我认为我可以做这样的事情。@case_studies=CaseStudy.call("some_named_scope")"some_named_scope"也是CaseStudy中的命名范围。我需要使用call的原因是因为我命名的范围与Controller中的Action名称相同,所以我想做这样的事情。@case_studies=CaseStudy.call(params[:action])编辑请原谅,我刚刚意识到我在考虑send方法,一些调用这个词是如何卡在我脑海中的。但是@case_studies=CaseStudy.send(params[:a

ruby - 当字符串默认不可变时,如何描述可变字符串?

当一个文件有pragma时:#frozen_string_literal:true默认情况下,该文件中所有作为文字写入的字符串都被卡住。当我希望我的字符串总体上是不可变的,因此我使用pragma,但想要有几个可变字符串时,推荐的编写它们的方法是什么?我能想到的是:String.new("foo") 最佳答案 我错过了。推荐的方法是使用+@方法字符串文字。(+"foo").frozen?#=>false(-"foo").frozen?#=>true"foo".frozen?#=>true

ruby - 表示 "at least one non-digit"的正则表达式

我想根据这个模式验证用户名:允许的字符:字母、数字、连字符、下划线第一个字符必须是字母或数字用户名不能全是数字这个正则表达式满足上面的1和2,但是我想不通如何满足3:/^[a-zA-Z\d][\w\-]+$/(我正在使用Ruby,如果相关的话) 最佳答案 不是很高效,但是很简单:/^(?!\d+$)[a-zA-Z\d][\w\-]+$/前瞻只是意味着:“后面不是一串数字,一直持续到最后”。 关于ruby-表示"atleastonenon-digit"的正则表达式,我们在StackOver

ruby - 只是为了好玩,我如何编写一个 ruby​​ 程序,一次缓慢地打印到 stdout 一个字符?

我认为这可能有效"abcdefghijk".each{|c|putcc;sleep0.25}我希望看到“abcdefj”一次打印一个字符,每个字符之间间隔0.25秒。但是整个字符串是一次打印出来的。 最佳答案 两件事:您需要使用.each_char来遍历字符。在Ruby1.8中,String.each将逐行进行。在Ruby1.9中,String.each已弃用。如果您希望字符立即出现,您应该手动刷新$stdout。否则,它们往往会被缓冲,以便字符在最后一次出现。.#!/usr/bin/envruby"abcddefghijk".ea

ruby-on-rails - RoR 字符类正则表达式

我的RubyonRails应用程序中有以下代码行,它检查给定的字符串是否包含韩文字符:isKorean=!/\p{Hangul}/.match(word).nil?它在控制台中完美运行,但会引发实际应用程序的语法错误:invalidcharacterpropertyname{Hangul}:/\p{Hangul}/我缺少什么以及如何让它发挥作用? 最佳答案 这是字符编码问题,需要补充:#encoding:utf-8到您正在使用该正则表达式的Ruby文件的顶部。如果您愿意,您可以使用您正在使用的字符类存在的任何编码而不是UTF-8。请

ruby-on-rails - 使用 Rails 在 PaperClip 中文件上传 Base64 编码的字符串

我有一个图像文件的base64编码字符串。我需要用回形针保存它我的Controller代码是@driver=User.find(6)encoded_file=Base64.encode64(File.open('/pjt_path/public/test.jpg').read)decoded_file=Base64.decode64(encoded_file)@driver.profile_pic=StringIO.open(decoded_file)@driver.save在我的用户模型中has_attached_file:profile_pic,:styles=>{:medium=

ruby - 在 ruby​​ 正则表达式中匹配换行符 `\n`

我试图理解为什么以下返回false:(**我应该放“输出0”**)puts"a\nb"=~Regexp.new(Regexp.escape("a\nb"),Regexp::MULTILINE|Regexp::EXTENDED)也许有人可以解释。我正在尝试从匹配字符串的多行字符串生成正则表达式。提前致谢 最佳答案 puts将始终返回nil。您的代码应该可以正常工作,尽管很长。=~返回匹配的位置,即0。您还可以使用:"a\nb"=~/a\sb/m或"a\nb"=~/a\nb/m注意:m选项在此示例中不是必需的,但演示了在没有Regexp

ruby - 拆分开始和结束时的空字符串

这个问题在这里已经有了答案:关闭10年前。PossibleDuplicate:SplitprobleminRuby在Ruby中,当我使用与字符串开头匹配的定界符拆分字符串时,它会在数组的初始位置给出一个空字符串:"abc".split(/a/)#=>["","bc"]但是当我用匹配字符串末尾的分隔符做类似的事情时,它不会给出空字符串:"abc".split(/c/)#=>["ab"]这在我看来不一致。这样的规范有什么理由吗?编辑如果它要与Perl的规范兼容,就像muu中的short答案一样,那么问题仍然是一样的:为什么它在Perl中是这样的?由于这个原因,现在它也变成了一个关于Perl